草庐IT

C++ 指向 vector 的指针

全部标签

c++ - 为什么 std::vector::at() 即使启用了优化也需要边界检查?

Windows中的libstdc++-6.dll有问题。这段代码:#include#includeintmain(){std::vectorx(10);std::cout编译很好,但是当我运行它时,我收到一条错误消息说Theprocedureentrypoint_ZSt24__throw_out_of_range_fmtPKczcouldnotbelocatedinthedlllibstdc++-6.dll我的问题是不是如何解决这个问题(这很可能是dll的错误版本,我只需要修复PATH)。然而,这让我意识到了一些意想不到的事情:当我打开优化时,上面的代码运行良好(不管错误的dll),即

c++ - 如何删除 vector 中的元素。 (删除无效)

当我使用“删除”删除vector中的元素时,并没有清除内存。例如,我制作了一个大小为2000的vector。创建后程序使用1,5MB内存。当我执行删除调用时,不会清除任何内容。所有的元素都消失了。但它们仍在内存中。例如:#include#includeusingnamespacestd;intmain(){//Makesavectorof2000itemsvectortest(200000);//Pausefortestpurposesystem("pause");//eraseallelementstest.erase(test.begin(),test.end());//Pause

c++ - 如何调用一个带有多个整数和一个整数 vector 的函数?

问题我正在尝试为一种玩具语言编写解释器,我希望它能够调用位于DLL中的函数。在一些external.dll我有:#includeextern"C"{__declspec(dllexport)voidprint(intval){printf("%i\n",val);}__declspec(dllexport)intadd(inta,intb){returna+b;}...morefunctions**thatIdon'tknowthennamesof**}假设我有一个std::stringfunc;这是DLL中过程的名称,可能是"print"或"add",和一个std::vectorar

C语言——指针详解(必收藏)

目录1.什么是指针?1.1概念1.2指针的大小​ 1.3指针类型的作用2.野指针 2.1野指针产生的原因2.2如何规避野指针3.指针运算 3.1指针+-整数3.2指针-指针3.3指针的关系运算 4.二级指针5.数组名*6.指针数组和数组指针 6.1指针数组*6.2数组指针  6.3举例区别含义7.数组参数和指针参数7.1数组参数7.2指针传参8.函数指针 9.函数指针数组9.1指向函数指针数组的指针*10.回调函数1.什么是指针?1.1概念简单的来说,指针就是地址。我们口头上说的指针其实指的是指针变量。指针变量就是一个存放地址的变量。1.2指针的大小 指针在32位机器下是4个字节,在64位机器

c++ - 有没有办法获取在处理信号期间访问的指针?

大概代码是这样的:#includevoidSegmentationFaultHandler(intsignal){if(signal==SIGSEGV){//howtocheckhereifit'sactualnullpointer?Throw(NullPointerException,"Objectpointernotsettoaninstanceofanobject.");}elseThrow(InvalidOperationException,"Signalhasbeeninterceptedbywrongfunction.");}intmain(){signal(SIGSEGV

windows - 64 位 Windows 8.1 和 Qt 上的 MIDI 应用程序 - 指针大小问题

我正在尝试开发一个C++Windows应用程序来处理来自某些MIDI设备的MIDI信息。我强制使用的操作系统是Windows8.164位。开发环境为Qt。在阅读了大量网页后,我发现Windows有一组低级函数来处理MIDI数据,允许将WindowsMIDI驱动程序与任何应用程序连接。这些功能在此处描述http://msdn.microsoft.com/en-us/library/windows/desktop/dd757277(v=vs.85).aspx到目前为止,我编写的软件工作正常,我能够在我的应用程序中处理传入的MIDI短消息。尽管如此,当涉及到将一些缓冲区从应用程序传递到驱动程

windows - 将Win32封装在一个类中——在CreateWindow中传递类指针

我看了很多关于这个主题的教程和帖子,他们都说我在我的CreateWindowEx()函数中传递类实例指针(this),然后存储它在窗口过程函数中,当WM_NCCREATE消息被发送时。我猜这是因为WM_NCCREATE应该是自创建窗口以来发送到窗口过程的第一条消息。几个问题/注意事项:通过调试,我了解到实际上WM_GETMINMAXINFO是第一条发送的消息,在WM_NCCREATE之前(至少在我的机器上是这样).这是否意味着我应该监听此消息而不是WM_NCCREATE?根据this热门文章,大家之所以在收到消息WM_NCCREATE后调用SetWindowLongPtr()是因为If

windows - 如何使用 Windows 符号链接(symbolic link)正确地 git clone 指向子模块中的文件夹

经过反复试验,我注意到可以提交使用mklink/DFoo..\..\Bar\Baz\Foo创建的链接(指向同一存储库中的另一个文件)即使在macOS上也可以毫无问题地克隆。不幸的是,当这个特定的链接指向一个子模块时,Windows在克隆时表现得很奇怪。原因很可能是存储在repo中的链接在克隆子模块之前被pull出。由于链接在这个特定时间指向任何地方,因此它们已损坏,并且即使在克隆子模块后仍将保持损坏状态。一种解决方法是del特定链接和gitcheckout--*以将其恢复到工作状态。但是我想避免手动执行此操作,我想知道是否还有其他方法。像强制子模块在repo本身之前被pull出之类的东

windows - 为什么 Windows 7 中的 %AppData% 似乎指向错误的文件夹?

查找和访问AppData文件夹(特别是Windows7)的最佳方法是在启动命令中键入%AppData%。但它需要我到C:\Users\user.name\AppData\Roaming当实际的AppData文件夹在上一层时,为什么我会转到Roaming文件夹?它发生在我的两台电脑上。 最佳答案 根“AppData”文件夹没有环境变量,因为任何人都不应该将数据放在那里。相反,应用程序根据数据的性质将数据放入“AppData”文件夹的子文件夹中。共有三个子文件夹:漫游本地局部低常规的旧%AppData%环境变量指向“Roaming”子文

windows - 给定一个指针,我如何找到它所属的 _HEAP_ENTRY?

我正在学习使用WinDbg,我可能会偏离正轨,但我假设如果我的程序没有使用分页堆,而不是“拥有”的_DPH_HEAP_BLOCK结构一个指向我的分配的指针,我会为分配的数据设置一个_HEAP_ENTRY。给定堆上已分配数据的地址,我如何找到与之对应的_HEAP_ENTRY(在WinDbg中),或者我的问题甚至没有意义?我的问题的根源是我想知道转储中的分配是否已释放或堆是否以某种方式损坏。 最佳答案 !heap-p-a启用页堆后,这会转储出有用的信息(可能包括最后一个分配/释放此堆block的人的调用堆栈)-我认为这可视化了_DPH_